Listing of Claims 



1 1 . (Previously Presented) A method of reducing the number of times a tree data structure is 

2 rebalanced comprising the steps of: 

3 (a) allowing a sub-tree of the tree data structure to grow until a number of 

4 unbalanced levels reaches a threshold greater than one; and 

5 (b) rebalancing the tree data structure when the threshold is reached. 

1 2. (Previously Presented) The method of claim 1 wherein the threshold is log 2 n for a tree 

2 data structure having about n nodes. 

1 3. (Previously Presented) The method of claim 1 wherein the threshold is a constant number 

2 of levels greater than a level of a balanced portion of the tree data structure. 

1 4. (Original) The method of claim 1 wherein the step of rebalancing the tree data structure 

2 further comprises: 

3 (a) developing first and second sets of rebalancing operation tasks, the first set of 

4 operation tasks operable to effect a first set of element state transitions and the 

5 second set of operation tasks operable to effect a second set of element state 

6 transitions, the first and second set of element state transition being distinct one 

7 from the other; 

8 (b) performing the first set of operation tasks in a first phase; and 

9 (c) performing the second set of operation tasks in a second phase. 
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1 5. (Previously Presented) A method of deferring the rebalancing of a tree data structure 

2 comprising the steps of: 

3 (a) allowing a sub-tree of the tree data structure to grow to an unbalanced length 

4 greater than one; and 

5 (b) rebalancing the tree data structure when the unbalanced length of the sub-tree 

6 reaches a threshold level. 

1 6. (Original) The method of claim 5 wherein the threshold level is log 2 n for a tree data 

2 structure having about ri nodes. 

1 7. (Original) The method of claim 5 wherein the threshold level is a constant number of levels 

2 greater than a level of a balanced portion of the tree data structure. 

1 8-9. (Cancelled) 

" 1 10. (Original) . A method of performing a rebalancing operation upon a tree data structure 

2 comprising the steps of: 

3 (a) allowing a sub-tree of the tree data structure to grow unbalanced to a threshold 

4 level greater than one; 

5 (b) developing, in the case where the sub-tree reaches the threshold level, first and 

6 second sets of rebalancing operation tasks, the first and second set of rebalancing 

7 operation tasks operable to effect a first and second set of element state transitions 

8 respectively; 

9 (c) performing the first set of operation tasks in a first phase; and 
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1 0 (d) performing the second set of operation tasks in a second phase. 

1 11-12. (Cancelled) 

1 13. (Currently Amended) A system for deferring the rebalancing of a tree data structure 

2 comprising: 

3 (a) a memory for storing the tree data structure; and 

4 (b) a processor coupled to the memory, the processor operable to track the 

5 performance of operations upon the tree data structure and rebalance the tree data 

6 structure when an-a number of unbalanced levels within a sub-tree of the tree data 

7 structure reaches a threshold greater than one. 

1 14. (Cancelled) 

1 15. (Previously Presented) A system comprising: 

2 means for storing a tree data structure; 

3 means for tracking the execution of operations upon the tree data structure; and 

'4 means for rebalancing the tree data structure when an unbalanced sub-tree of the tree data 

5 structure reaches a threshold level greater than one, the rebalancing including a 

6 first rebalancing phase in which rebalancing operations are executed in parallel 

7 - and nodes of the unbalanced sub-tree are unlocked, and a second rebalancing 

8 phase in which different rebalancing operations are executed. 
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1 16. (Cancelled) 



1 17. (Previously Presented) A method of deferring the rebalancing of a tree data 

2 structure comprising the steps of: 

3 (a) tracking the performance of operations upon the tree data structure; and 

4 (b) rebalancing the tree data structure when an unbalanced sub-tree of the tree 

5 data structure reaches a threshold level greater than one, the rebalancing 

6 further comprising creating a first set of rebalancing operation tasks, the 

7 first set of rebalancing operation tasks being characterized by navigation 

8 of the tree data structure using at least an existing link, creating a second 

9 set of rebalancing operation tasks, the second set of rebalancing operation 

10 tasks being different from the first set of rebalancing operation tasks and 

1 1 being characterized by location of elements within the tree data structure 

12 using at least one pointer external to the tree data structure and created by 

13 the first set of rebalancing operation tasks, and performing at least one 

14 operation task of the first set of rebalancing operation tasks in a first phase 

15 and at least one of the second set of rebalancing operation tasks in a 

16 second phase. 

1 18. (Original) A method of deferring the rebalancing of a tree data structure comprising 

2 the steps of: 

3 (a) tracking the performance of operations upon the tree data structure; and 

4 (b) rebalancing the tree data structure when an unbalanced sub-tree of the tree 

5 data structure reaches a threshold level greater than one, the rebalancing 
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further comprising executing simultaneous rebalancing operations on the 
tree data structure including performing any first phase operation task of 
each of the simultaneous rebalancing operations in a first phase using 
parallel processes, developing a set of serial rebalancing operations during 
the first phase, and performing any second phase operation task of each of 
the simultaneous rebalancing operations in a second phase, the second 
phase operation task having at least one of the set of serial rebalancing 
operations. 



1 19. (Previously Presented) A method of rebalancing a tree data structure, the method 

2 comprising: 

3 allowing a sub-tree of the tree data structure to grow unbalanced until a threshold 

4 level is reached; 

5 developing a first set of rebalancing operation tasks, the first set of operation tasks 

6 operable in parallel on one or more unlocked nodes of the tree data 

7 structure during a first phase of the rebalancing; 

8 developing a second set of rebalancing operation tasks during execution of the 

9 first set of rebalancing operation tasks; and 

10 executing the second set of rebalancing operation tasks during a second phase of 

11 the rebalancing. 

1 20. (Previously Presented) The method of claim 19, wherein execution of the second set 

2 of rebalancing operation tasks is performed without navigating between nodes of 

3 the sub-tree. 
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1 21. (Previously Presented) The method of claim 19, wherein execution of the first set of 

2 rebalancing operations includes generating a list of pointers to nodes requiring 

3 updating in the second phase of rebalancing. 

1 22. (Previously Presented) A method of rebalancing a tree data structure, the method 

2 comprising: 

3 allowing a sub-tree of the tree data structure to grow unbalanced until a threshold 

4 level is reached; 

5 executing a first set of rebalancing operation tasks during a first rebalancing 

6 phase, the first rebalancing phase being characterized by navigation 

7 between nodes of the sub-tree; and 

8 executing a second set of rebalancing operation tasks during a second rebalancing 

9 phase, the second rebalancing phase including navigation to two or more 

10 nodes of the sub-tree, the navigation being independent of pointers 

1 1 between nodes of the sub-tree. 

1 23. (Previously Presented) The method of claim 22, wherein the first set of rebalancing 

2 operation tasks are performed on unlocked nodes of the sub-tree. 

1 24. (Previously Presented) The method of claim 22, wherein the first set of rebalancing 

2 operation tasks includes a plurality of operation tasks configured for parallel 

3 execution. 
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1 25. (Currently Amended) A method of maintaining a tree data structure, the method 

2 comprising: 

3 allowing the tree data structure to grow unbalanced; 

4 performing a_first set of rebalancing operation tasks during a first rebalancing 

5 phase on a plurality of nodes in the tree data structure, the first set of 

6 rebalancing operation tasks being configured for execution while the 

7 plurality of nodes are unlocked and for insertion and deletion of nodes; 

8 and 

9 performing a second set of rebalancing operation tasks on the plurality of nodes in 

10 a second rebalancing phase, the second set of rebalancing operation tasks 

1 1 being different than the first set of rebalancing operation tasks and being 

12 configured for further operations on the plurality of nodes, the second 

13 rebalancing phase occurring after completion of the first rebalancing 

14 phase. 

1 26. (Previously Presented) The method of claim 25, wherein the first set of rebalancing 

2 operation tasks are performed in parallel. 

1 27. (Previously Presented) A method comprising: 

2 storing a tree data structure; 

3 tracking the execution of operations upon the tree data structure; and 

4 rebalancing the tree data structure when an unbalanced sub-tree of the tree data 

5 structure reaches a threshold level greater than one, the rebalancing 

6 including a first rebalancing phase in which rebalancing operations are 
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executed in parallel and nodes of the unbalanced sub-tree are unlocked, 
and a second rebalancing phase in which different rebalancing operations 
are executed. 
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